home *** CD-ROM | disk | FTP | other *** search
/ Personal Computer World 2009 February / PCWFEB09.iso / Software / Linux / Kubuntu 8.10 / kubuntu-8.10-desktop-i386.iso / casper / filesystem.squashfs / usr / include / linux / dvb / video.h < prev   
Encoding:
C/C++ Source or Header  |  2008-10-24  |  8.5 KB  |  276 lines

  1. /*
  2.  * video.h
  3.  *
  4.  * Copyright (C) 2000 Marcus Metzler <marcus@convergence.de>
  5.  *                  & Ralph  Metzler <ralph@convergence.de>
  6.  *                    for convergence integrated media GmbH
  7.  *
  8.  * This program is free software; you can redistribute it and/or
  9.  * modify it under the terms of the GNU Lesser General Public License
  10.  * as published by the Free Software Foundation; either version 2.1
  11.  * of the License, or (at your option) any later version.
  12.  *
  13.  * This program is distributed in the hope that it will be useful,
  14.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16.  * GNU General Public License for more details.
  17.  *
  18.  * You should have received a copy of the GNU Lesser General Public License
  19.  * along with this program; if not, write to the Free Software
  20.  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
  21.  *
  22.  */
  23.  
  24. #ifndef _DVBVIDEO_H_
  25. #define _DVBVIDEO_H_
  26.  
  27.  
  28.  
  29. #include <asm/types.h>
  30. #include <stdint.h>
  31. #include <time.h>
  32.  
  33.  
  34. typedef enum {
  35.     VIDEO_FORMAT_4_3,     /* Select 4:3 format */
  36.     VIDEO_FORMAT_16_9,    /* Select 16:9 format. */
  37.     VIDEO_FORMAT_221_1    /* 2.21:1 */
  38. } video_format_t;
  39.  
  40.  
  41. typedef enum {
  42.      VIDEO_SYSTEM_PAL,
  43.      VIDEO_SYSTEM_NTSC,
  44.      VIDEO_SYSTEM_PALN,
  45.      VIDEO_SYSTEM_PALNc,
  46.      VIDEO_SYSTEM_PALM,
  47.      VIDEO_SYSTEM_NTSC60,
  48.      VIDEO_SYSTEM_PAL60,
  49.      VIDEO_SYSTEM_PALM60
  50. } video_system_t;
  51.  
  52.  
  53. typedef enum {
  54.     VIDEO_PAN_SCAN,       /* use pan and scan format */
  55.     VIDEO_LETTER_BOX,     /* use letterbox format */
  56.     VIDEO_CENTER_CUT_OUT  /* use center cut out format */
  57. } video_displayformat_t;
  58.  
  59. typedef struct {
  60.     int w;
  61.     int h;
  62.     video_format_t aspect_ratio;
  63. } video_size_t;
  64.  
  65. typedef enum {
  66.     VIDEO_SOURCE_DEMUX, /* Select the demux as the main source */
  67.     VIDEO_SOURCE_MEMORY /* If this source is selected, the stream
  68.                    comes from the user through the write
  69.                    system call */
  70. } video_stream_source_t;
  71.  
  72.  
  73. typedef enum {
  74.     VIDEO_STOPPED, /* Video is stopped */
  75.     VIDEO_PLAYING, /* Video is currently playing */
  76.     VIDEO_FREEZED  /* Video is freezed */
  77. } video_play_state_t;
  78.  
  79.  
  80. /* Decoder commands */
  81. #define VIDEO_CMD_PLAY        (0)
  82. #define VIDEO_CMD_STOP        (1)
  83. #define VIDEO_CMD_FREEZE      (2)
  84. #define VIDEO_CMD_CONTINUE    (3)
  85.  
  86. /* Flags for VIDEO_CMD_FREEZE */
  87. #define VIDEO_CMD_FREEZE_TO_BLACK         (1 << 0)
  88.  
  89. /* Flags for VIDEO_CMD_STOP */
  90. #define VIDEO_CMD_STOP_TO_BLACK          (1 << 0)
  91. #define VIDEO_CMD_STOP_IMMEDIATELY         (1 << 1)
  92.  
  93. /* Play input formats: */
  94. /* The decoder has no special format requirements */
  95. #define VIDEO_PLAY_FMT_NONE         (0)
  96. /* The decoder requires full GOPs */
  97. #define VIDEO_PLAY_FMT_GOP          (1)
  98.  
  99. /* The structure must be zeroed before use by the application
  100.    This ensures it can be extended safely in the future. */
  101. struct video_command {
  102.     __u32 cmd;
  103.     __u32 flags;
  104.     union {
  105.         struct {
  106.             __u64 pts;
  107.         } stop;
  108.  
  109.         struct {
  110.             /* 0 or 1000 specifies normal speed,
  111.                1 specifies forward single stepping,
  112.                -1 specifies backward single stepping,
  113.                >1: playback at speed/1000 of the normal speed,
  114.                <-1: reverse playback at (-speed/1000) of the normal speed. */
  115.             __s32 speed;
  116.             __u32 format;
  117.         } play;
  118.  
  119.         struct {
  120.             __u32 data[16];
  121.         } raw;
  122.     };
  123. };
  124.  
  125. /* FIELD_UNKNOWN can be used if the hardware does not know whether
  126.    the Vsync is for an odd, even or progressive (i.e. non-interlaced)
  127.    field. */
  128. #define VIDEO_VSYNC_FIELD_UNKNOWN      (0)
  129. #define VIDEO_VSYNC_FIELD_ODD         (1)
  130. #define VIDEO_VSYNC_FIELD_EVEN        (2)
  131. #define VIDEO_VSYNC_FIELD_PROGRESSIVE    (3)
  132.  
  133. struct video_event {
  134.     int32_t type;
  135. #define VIDEO_EVENT_SIZE_CHANGED    1
  136. #define VIDEO_EVENT_FRAME_RATE_CHANGED    2
  137. #define VIDEO_EVENT_DECODER_STOPPED     3
  138. #define VIDEO_EVENT_VSYNC         4
  139.     time_t timestamp;
  140.     union {
  141.         video_size_t size;
  142.         unsigned int frame_rate;    /* in frames per 1000sec */
  143.         unsigned char vsync_field;    /* unknown/odd/even/progressive */
  144.     } u;
  145. };
  146.  
  147.  
  148. struct video_status {
  149.     int                   video_blank;   /* blank video on freeze? */
  150.     video_play_state_t    play_state;    /* current state of playback */
  151.     video_stream_source_t stream_source; /* current source (demux/memory) */
  152.     video_format_t        video_format;  /* current aspect ratio of stream*/
  153.     video_displayformat_t display_format;/* selected cropping mode */
  154. };
  155.  
  156.  
  157. struct video_still_picture {
  158.     char *iFrame;        /* pointer to a single iframe in memory */
  159.     int32_t size;
  160. };
  161.  
  162.  
  163. typedef
  164. struct video_highlight {
  165.     int     active;      /*    1=show highlight, 0=hide highlight */
  166.     uint8_t contrast1;   /*    7- 4  Pattern pixel contrast */
  167.                  /*    3- 0  Background pixel contrast */
  168.     uint8_t contrast2;   /*    7- 4  Emphasis pixel-2 contrast */
  169.                  /*    3- 0  Emphasis pixel-1 contrast */
  170.     uint8_t color1;      /*    7- 4  Pattern pixel color */
  171.                  /*    3- 0  Background pixel color */
  172.     uint8_t color2;      /*    7- 4  Emphasis pixel-2 color */
  173.                  /*    3- 0  Emphasis pixel-1 color */
  174.     uint32_t ypos;       /*   23-22  auto action mode */
  175.                  /*   21-12  start y */
  176.                  /*    9- 0  end y */
  177.     uint32_t xpos;       /*   23-22  button color number */
  178.                  /*   21-12  start x */
  179.                  /*    9- 0  end x */
  180. } video_highlight_t;
  181.  
  182.  
  183. typedef struct video_spu {
  184.     int active;
  185.     int stream_id;
  186. } video_spu_t;
  187.  
  188.  
  189. typedef struct video_spu_palette {      /* SPU Palette information */
  190.     int length;
  191.     uint8_t *palette;
  192. } video_spu_palette_t;
  193.  
  194.  
  195. typedef struct video_navi_pack {
  196.     int length;          /* 0 ... 1024 */
  197.     uint8_t data[1024];
  198. } video_navi_pack_t;
  199.  
  200.  
  201. typedef uint16_t video_attributes_t;
  202. /*   bits: descr. */
  203. /*   15-14 Video compression mode (0=MPEG-1, 1=MPEG-2) */
  204. /*   13-12 TV system (0=525/60, 1=625/50) */
  205. /*   11-10 Aspect ratio (0=4:3, 3=16:9) */
  206. /*    9- 8 permitted display mode on 4:3 monitor (0=both, 1=only pan-sca */
  207. /*    7    line 21-1 data present in GOP (1=yes, 0=no) */
  208. /*    6    line 21-2 data present in GOP (1=yes, 0=no) */
  209. /*    5- 3 source resolution (0=720x480/576, 1=704x480/576, 2=352x480/57 */
  210. /*    2    source letterboxed (1=yes, 0=no) */
  211. /*    0    film/camera mode (0=camera, 1=film (625/50 only)) */
  212.  
  213.  
  214. /* bit definitions for capabilities: */
  215. /* can the hardware decode MPEG1 and/or MPEG2? */
  216. #define VIDEO_CAP_MPEG1   1
  217. #define VIDEO_CAP_MPEG2   2
  218. /* can you send a system and/or program stream to video device?
  219.    (you still have to open the video and the audio device but only
  220.     send the stream to the video device) */
  221. #define VIDEO_CAP_SYS     4
  222. #define VIDEO_CAP_PROG    8
  223. /* can the driver also handle SPU, NAVI and CSS encoded data?
  224.    (CSS API is not present yet) */
  225. #define VIDEO_CAP_SPU    16
  226. #define VIDEO_CAP_NAVI   32
  227. #define VIDEO_CAP_CSS    64
  228.  
  229.  
  230. #define VIDEO_STOP                 _IO('o', 21)
  231. #define VIDEO_PLAY                 _IO('o', 22)
  232. #define VIDEO_FREEZE               _IO('o', 23)
  233. #define VIDEO_CONTINUE             _IO('o', 24)
  234. #define VIDEO_SELECT_SOURCE        _IO('o', 25)
  235. #define VIDEO_SET_BLANK            _IO('o', 26)
  236. #define VIDEO_GET_STATUS           _IOR('o', 27, struct video_status)
  237. #define VIDEO_GET_EVENT            _IOR('o', 28, struct video_event)
  238. #define VIDEO_SET_DISPLAY_FORMAT   _IO('o', 29)
  239. #define VIDEO_STILLPICTURE         _IOW('o', 30, struct video_still_picture)
  240. #define VIDEO_FAST_FORWARD         _IO('o', 31)
  241. #define VIDEO_SLOWMOTION           _IO('o', 32)
  242. #define VIDEO_GET_CAPABILITIES     _IOR('o', 33, unsigned int)
  243. #define VIDEO_CLEAR_BUFFER         _IO('o',  34)
  244. #define VIDEO_SET_ID               _IO('o', 35)
  245. #define VIDEO_SET_STREAMTYPE       _IO('o', 36)
  246. #define VIDEO_SET_FORMAT           _IO('o', 37)
  247. #define VIDEO_SET_SYSTEM           _IO('o', 38)
  248. #define VIDEO_SET_HIGHLIGHT        _IOW('o', 39, video_highlight_t)
  249. #define VIDEO_SET_SPU              _IOW('o', 50, video_spu_t)
  250. #define VIDEO_SET_SPU_PALETTE      _IOW('o', 51, video_spu_palette_t)
  251. #define VIDEO_GET_NAVI             _IOR('o', 52, video_navi_pack_t)
  252. #define VIDEO_SET_ATTRIBUTES       _IO('o', 53)
  253. #define VIDEO_GET_SIZE             _IOR('o', 55, video_size_t)
  254. #define VIDEO_GET_FRAME_RATE       _IOR('o', 56, unsigned int)
  255.  
  256. /**
  257.  * VIDEO_GET_PTS
  258.  *
  259.  * Read the 33 bit presentation time stamp as defined
  260.  * in ITU T-REC-H.222.0 / ISO/IEC 13818-1.
  261.  *
  262.  * The PTS should belong to the currently played
  263.  * frame if possible, but may also be a value close to it
  264.  * like the PTS of the last decoded frame or the last PTS
  265.  * extracted by the PES parser.
  266.  */
  267. #define VIDEO_GET_PTS              _IOR('o', 57, __u64)
  268.  
  269. /* Read the number of displayed frames since the decoder was started */
  270. #define VIDEO_GET_FRAME_COUNT         _IOR('o', 58, __u64)
  271.  
  272. #define VIDEO_COMMAND            _IOWR('o', 59, struct video_command)
  273. #define VIDEO_TRY_COMMAND        _IOWR('o', 60, struct video_command)
  274.  
  275. #endif /*_DVBVIDEO_H_*/
  276.